IN THE CLAIMS: 



What is claimed is: 

1. (Currently amended) A method for configuring a microcontroller, said 
method comprising: 

displaying a first graphical user interface on a display device of a 
computer system, said first graphical user interface comprising a collection of 
virtual blocks in a design system; 

receiving at said computer system a selection of a user module, wherein 
said user module comprises information for implementing a function using a 
programmable physical block , and wherein said user module is represented by 
first markup language data that includes information defining how configuration 
re gisters for said microcontroller are to be programmed in order to implement 
said function, and wherein said programmable physical block is represented by 
second markup language data that includes information defining physical 
addresses of said configuration registers: 

displaying on said display device a second graphical user interface 
operable for receiving user-specifiable information about said user module; 

assigning a virtual block taken from said collection to said user module, 
wherein said virtual block corresponds to said programmable physical block; 
and 

constructing computer-generated source code, wherein constructing the 
computer-generated source code comprisesi 

linking said first markup language data and said second markup 
language data: 

substituting said user-specifiable information comprising 
information specific to said user module, information specific to said 
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function and information specific to a control parameter of said function 
for generic information in said template files to produce assembly, include 
and header files 

automatically constructing aosombly code holding configuration 
information for said programmable physical block, wherein said configuration 
information io based on said user spocifiablc information and compriooo 
information that io loaded into a rogiotor of said programmable physical block to 
cause said programmable physical block to perform said function . 

2. (Original) The method of Claim 1, wherein said function comprises a pulse 
width modulator. 

3. (Original) The method of Claim 1, wherein said function comprises a timer. 

4. (Original) The method of Claim 1, wherein said function comprises an analog- 
to-digital converter. 

5. (Original) The method of Claim 1, wherein said function comprises a digital- 
to-analog converter. 

6. (Original) The method of Claim 1, wherein said function comprises a counter. 

7. (Original) The method of Claim 1, wherein said function comprises a signal 
amplifier. 

8. (Original) The method of Claim 1, wherein said function provides serial 
communication. 
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9. (Original) The method of Claim 1, wherein said collection is displayed as a 
two dimensional array of programmable analog virtual blocks and 
programmable digital virtual blocks. 

10. (Original) The method of Claim 1, wherein said assigning further comprises 
assigning a second virtual block to said user module. 

11. (Previously Presented) The method of Claim 1, wherein said source code 
comprises a symbolic name for a register address in said programmable physical 
block. 

12. (Original) The method of Claim 11 wherein said symbolic name is derived 
from said function. 

13. (Currently amended) A method of configuring a microcontroller having a 
physical programmable block, said method comprising: 

receiving, at a computer system, a selection of a user module defining a 
circuit design, wherein said user module comprises information for 
implementing a function using said programmable physical block , wherein said 
user module is represented by first markup language data that include 
information defining how configuration registers for said microcontroller are to 
be programmed in order to implement said function and wherein said 
pro grammable physical block is represented by second markup language data 
that includes information defining physical addresses of said configuration 
re gisters: 
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displaying a graphical user interface on a display device of said computer 
system, said graphical user interface operable for receiving user-specifiable 
information about said user module, wherein said user-specifiable information 
comprises configuration information that is used to establish a value for a 
programmable characteristic of said programmable physical block; 

assigning a virtual block in a design system where said virtual block 
corresponds to said programmable physical block; and 

automatically constructing assembly code comprising said configuration 
information for said programmable physical block to implement said circuit 
design, wherein automatically constructing assembly code further comprises 
linking said first markup language data and said second markup language data, 
wherein said assembly code is constructed from template assembly code by 
substituting said user-specifiable information and information specific to said 
circuit design for generic information in said template assembly code, and 
wherein said assembly code contains configuration information for said 
programmable physical block, wherein said configuration information is based 
on said user-specifiable information and comprises information that when 
loaded into a register of said programmable physical block cause said 
programmable physical block to perform said function. 

14. (Previously Presented) The method of Claim 13, wherein said automatically 
constructing further comprises: 

computing a register address for a register within said programmable 
physical block; 

determining a symbolic name for said register address, said symbolic 
name corresponding to said user module and said circuit design; and 



Application No.: 09/998,848 



-5- 



Atty. Docket No.: CD01177M 



substituting said symbolic name for a generic name in said template 
assembly code. 

15. (Canceled). 

16. (Previously Presented) The method of Claim 13, wherein said automatically 
constructing further comprises: 

determining a symbolic name corresponding to said user module and said 
circuit design; 

computing a register address for a register within said programmable 

physical block; 

assigning said symbolic name to said register address; and 

placing said symbolic name into said assembly code in place of a generic 

name provided in said template assembly code. 

17-25. (Canceled). 

26. (Previously presented) A computer system comprising a processor coupled 
to a bus, a display device coupled to said bus, and a memory coupled to said bus, 
said memory containing instructions to implement a method for configuring a 
microcontroller, said method comprising: 

displaying on said display device a first graphical user interface 
comprising a collection of virtual blocks in a design system; 

receiving at said computer system a selection of a user module, wherein 
said user module comprises information for implementing a function using a 
programmable physical block, said user module represented by first markup 
language data that includes information defining how configuration registers for 
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said microcontroller are to be programmed in order to implement said function, 
said programmable physical block represented by second markup language data 
that includes information defining physical addresses of said configuration 
registers; 

displaying on said display device a second graphical user interface 
operable for receiving user-specifiable information about said user module; 

assigning a virtual block taken from said collection to said user module, 
wherein said virtual block corresponds to said programmable physical block; 
and 

automatically constructing assembly code holding configuration 
information for said programmable physical block, wherein said configuration 
information is based on said user-specifiable information and comprises 
information that is loaded into a register of said programmable physical block to 
cause said programmable physical block to perform said function, said 
automatically constructing comprising: 

linking said first markup language data and said second markup language 

data; 

determining a symbolic name corresponding to said user module and said 
function; 

computing a register address for a register within said programmable 
physical block; 

assigning said symbolic name to said register address; 
placing said symbolic name into said assembly code; 
reading template files; 

substituting said user-specifiable comprising information specific to said 
user module, information specific to said function and information specific to a 
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control parameter of said function for generic information in said template files 
to produce assembly, include and header files; 

compiling said assembly, include and header files to produce an 
executable file; 

downloading said executable file as a code block to a memory of said 
microcontroller; and 

executing said code block to configure said programmable physical block. 

27. (Original) The computer system of Claim 26, wherein said collection is 
displayed as a two dimensional array. 

28. (Original) The computer system of Claim 26, wherein said assigning further 
comprises assigning a second virtual block to said user module. 

29. (Previously Presented) The computer system of Claim 26, wherein said 
assembly code further comprises a symbolic name for a register address in said 
programmable physical block. 

30. (Original) The computer system of Claim 26 wherein said symbolic name is 
derived from said function. 

31-35. (Canceled) 

36. (Previously presented) The method of Claim 1 wherein said constructing the 
computer-generated source code further comprises: 
reading the template file; 



Application No.: 09/998,848 



-8- 



Atty. Docket No.: CD01177M 



producing assembly, include, and header files from the template file, 
wherein said user-specifiable information comprises information specific to said 
user module, information specific to said function and information specific to a 
control parameter of said function; 

compiling said assembly, include and header files to produce an 
executable file; 

downloading said executable file as a code block to a memory of said 
microcontroller; and 

executing said code block to configure said programmable physical block. 

37. (jCanceledfai]) 

38. (Currently amended) The method of Claim 14 wherein said user modulo is 
roprosontod by first markup language data that includoo information defining 
how configuration rogistors for said microcontroller arc to bo programmed in 
order to implomont said fvmction and wherein said programmable physical block 
is roprosontod by second markup language data that includes information 
defining physical addroosoo of said configuration registers , wherein further said 
automatically constructing further comprises: 

linking said first markiip language data and said second markup language 

data; 

reading template files; 

substituting said user-specifiable comprising information specific to said 
user module, information specific to said function and information specific to a 
control parameter of said function for generic information in said template files 
to produce assembly, include and header files; 
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compiling said assembly, include and header files to produce an 
executable file; 

downloading said executable file as a code block to a memory of said 
microcontroller; and 

executing said code block to configure said programmable physical block. 
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